## Report

## COL216 Assignment-4

CHIRAG MOHAPATRA

2018CS50403

VISHAL BINDAL

2018CS50425

- In this assignment, we designed a block memory RAM and input instructions into it using a .coe file. Then, we read the instructions one by one and executed them.
- Our program takes one clock cycle for add, sub, sll and srl instructions and two clock cycles for lw and sw instructions. We have defined different states to achieve this in synchronous process.
- On the seven segment display, we print either the clock cycle count or the lower 16 bits of the last instruction to be executed. They can be toggled using a switch.
- For our main process, we have used a 1 kHz clock and for the memory, we have provided the 100 Mhz clock. This was done after extensive testing and observing that the memory takes a bit more time. This ensures that dina and douta are updated when addra is changed, before the next clock cycle of the main process.

## Our test cases are:

| Test case no. | Instruction<br>(assembly/words)                                              | Instruction(machine)                     | Final<br>Output |
|---------------|------------------------------------------------------------------------------|------------------------------------------|-----------------|
| 1             | store \$0 in 1024(\$1) add \$0,\$0,\$0 sub \$1, \$0, \$1 load \$2, 1022(\$1) | 101011000010000000001000000000, 00000000 | 2               |
| 2             | store \$0 in 1024(\$1)                                                       | 10101100001000000000010000000000,        | 2               |
|               |                                                                              |                                          |                 |

| _ |                        |                                         |   |
|---|------------------------|-----------------------------------------|---|
|   | sll \$0,1              | 000000000000000000000000000000000000000 |   |
|   | sub \$1 , \$0, \$1     | 000000000000001000010000100010,         |   |
|   | load \$2, 1022(\$1)    | 100011000010001000000011111111110;      |   |
|   |                        |                                         |   |
| 3 | store \$0 in 1024(\$1) | 101011000010000000001000000000000000000 | 2 |
|   | sll \$0,2              | 000000000000000000000000000000000000000 |   |
|   | srl \$0,1              | 0000000000000000000000000000001000010,  |   |
|   | sub \$1 , \$0, \$1     | 00000000000001000010000100010,          |   |
|   | load \$2, 1022(\$1)    | 100011000010001000000011111111110;      |   |
|   |                        |                                         |   |
| 4 | store \$0 in 1000(\$0) | 10101100000000000000001111101000,       | 5 |
|   | store \$1 in 1001(\$0) | 10101100000000010000001111101001,       |   |
|   | add \$2, \$1, \$0      | 000000000100000001000000100000,         |   |
|   | sub \$3, \$1, \$0      | 0000000001000000001100000100010,        |   |
|   | store \$2 in 1003(\$1) | 10101100001000100000001111101011,       |   |
|   | store \$3 in 1004(\$1) | 10101100001000110000001111101100,       |   |
|   | load 1000(\$0) in \$4  | 10001100000001000000001111101000,       |   |
|   | load 1001(\$0) in \$5  | 10001100000001010000001111101001,       |   |
|   | load 1002(\$0) in \$6  | 10001100000001100000001111101010,       |   |
|   | load 1003(\$0) in \$7  | 10001100000001110000001111101011,       |   |
|   | add \$6, \$6, \$7      | 0000000110001110011000000100000,        |   |
|   | add \$5, \$5, \$6      | 0000000101001100010100000100000,        |   |
|   | add \$4, \$5, \$4      | 000000010100100001000000100000;         |   |
|   |                        |                                         |   |

| 5 | sll \$0, \$0, 1   | 000000000000000000000000000000000000000 | 256        |
|---|-------------------|-----------------------------------------|------------|
|   | sll \$2, \$0, 2   | 0000000000000000001000010000000,        |            |
|   | sll \$2, \$2, 4   | 0000000000000100001000100000000;        |            |
| 6 | sll \$0, \$0, 10  | 000000000000000000001010000000,         | 64         |
|   | srl \$2, \$0, 5   | 0000000000000000001000101000010;        |            |
| 7 | sll \$0, \$0, 3   | 000000000000000000000011000000,         | 8          |
|   | add \$0, \$0, \$1 | 00000000000001000000000100000,          |            |
|   | srl \$0, \$0, 1   | 000000000000000000000000000000000000000 |            |
| 8 | sub \$0, \$1, \$0 | 00000000100000000000000100010,          | 32         |
|   | sll \$0, \$0, 5   | 000000000000000000000000000000000000000 |            |
| 9 | sll \$2, \$0, 14  | 0000000000000000001001110000000,        | 2^15 +     |
|   | sll \$1, \$0, 13  | 0000000000000000000101101000000,        | 2^14 + 2^6 |
|   | sll \$0, \$0, 5   | 000000000000000000000000000000000000000 |            |
|   | add \$1, \$0, \$1 | 0000000000000010000100000100000,        |            |
|   | add \$2, \$2, \$1 | 000000001000001000100000100000;         |            |